/**
 * 53. 最大子数组和
 */
public class Exerciser1 {
    public int maxSubArray(int[] nums) {
        int n = nums.length;
        int[] dp = new int[n + 1];
        dp[0] = 0;
        int ret = Integer.MIN_VALUE; // 最后返回的是 子数组的最大和，而不是让其下标到达最后位置的值
        for(int i = 1;i <= n;i++) {
            dp[i] = Math.max(nums[i - 1],dp[i - 1] + nums[i - 1]);
            ret = Math.max(dp[i],ret);
        }
        return ret;
    }
}
